//1. 安装 mongoose
//2. 导入 mongoose
const mongoose = require('mongoose');

//设置 strictQuery 为 true
// mongoose.set('strictQuery', true);

//3. 连接 mongodb 服务                        数据库的名称
mongoose.connect('mongodb://127.0.0.1:27017/bilibili');

//4. 设置回调
// 设置连接成功的回调  once 一次   事件回调函数只执行一次
mongoose.connection.once('open', () => {
    //5. 创建文档的结构对象
    //设置集合中文档的属性以及属性值的类型
    let BookSchema = new mongoose.Schema({
        name: String,
        author: String,
        price: Number,
        is_hot: Boolean
    });

    // 6. 创建模型对象  对文档操作的封装对象
    let BookModel = mongoose.model('novel', BookSchema);

    //字段筛选 _id是一个下划线
    // BookModel.find().select({name:1,price:1,_id:0}).exec((error, data) => {
    //     if (error) {
    //         console.log(error);
    //         return;
    //     }
    //     console.log(data);
    //     mongoose.disconnect();
    // })

    //数据排序 1表示正序 -1表示倒序
    // BookModel.find().select({_id: 0, name: 1, price: 1}).sort({price: 1}).exec((error, data) => {
    //     if (error) {
    //         console.log(error);
    //         return;
    //     }
    //     console.log(data);
    //     mongoose.disconnect();
    // });


    //数据截取 skip跳过 limit限制
    BookModel.find().select({_id: 0, name: 1, price: 1}).skip(3).limit(3).sort({price: 1}).exec((error, data) => {
        if (error) {
            console.log(error);
            return;
        }
        console.log(data);
        mongoose.disconnect();
    });

});

// 设置连接错误的回调
mongoose.connection.on('error', () => {
    console.log('连接失败');
});

//设置连接关闭的回调
mongoose.connection.on('close', () => {
    console.log('连接关闭');
});

